datasets

1. Analysis by geography

1.1 Comparing beneficiaries reached and PIN by state and region

The PIN figures originated from the WFP township-level calculations for the FSC based on the combination of food insecure persons and IDPs.

Currently the beneficiaries reached by the Food Security Cluster far exceed the figures for People in Need established in 2021. 2,088,142 have been reached throughout the first three quarters of 2021; this is 71% of the cluster PIN; however, as we can see, the response has been heavily skewed towards Yangon and Rakhine.

1.2 Beneficiaries and PIN by state and region

Joining, by = “admin3_pcode”

Beneficiaries reached and PIN by state/region
state beneficiaries %_of_ben PIN %_of_PIN %_PIN_reached
Yangon 1,274,906 61.27 1,946,729 14.58 65.49
Rakhine 430,247 20.68 1,000,300 7.49 43.01
Kachin 87,452 4.2 565,037 4.23 15.48
Mon 43,442 2.09 479,600 3.59 9.06
Kayah 15,920 0.77 175,915 1.32 9.05
Kayin 46,932 2.26 521,733 3.91 9
Shan (North) 64,794 3.11 1,040,211 7.79 6.23
Chin 13,550 0.65 297,681 2.23 4.55
Mandalay 24,829 1.19 774,956 5.8 3.2
Ayeyarwady 55,276 2.66 1,873,441 14.03 2.95
Shan (South) 9,304 0.45 993,317 7.44 0.94
Sagaing 8,090 0.39 870,919 6.52 0.93
Bago (East) 4,312 0.21 729,561 5.46 0.59
Magway 1,695 0.08 855,823 6.41 0.2
Bago (West) 0 0 500,694 3.75 0
Shan (East) 0 0 367,238 2.75 0
Tanintharyi 0 0 362,733 2.72 0
Nay Pyi Taw 0 0 0 0 NA

In general, there is large mismatch between a state’s share of beneficiaries and its share of the PIN – notably, Yangon constitutes 61% of all beneficiaries but only 15% of the nationwide PIN. Although Yangon has the highest share of people in need, it should also be stressed that the percentage of it’s population that is vulnerable – that is, either food insecure or internally displaced – is one of the lowest in the country, at 22%, with only Magway, Sagaing and Mandalay having lower percentages:

Vulnerability here has been defined as the proportion of the population who are

1.3 Township-level

Just as the response has been very skewed at the state and region level, the same is true at the township level. These 10 townships below are where 80% of all beneficiaries have been reached despite only constituting 15% of the PIN – in particular, Dagon Myothit (Seikkan) and Hlaingtharya have beneficiary figures that are 633% and 430% of their PIN respectively. For reference, the median percentage of people in need covered per township in the areas we work in is 7%.

Top 10 townships by beneficiaries reached
township beneficiaries pc_of_total pin pc_of_pin pc_reached partners
Hlaingtharya 772,658 37 179,313 3.52 430.9 5
Dagon Myothit (Seikkan) 276,430 13.24 43,650 0.86 633.3 2
Dala 170,463 8.16 45,060 0.88 378.3 3
Sittwe 147,864 7.08 128,717 2.53 114.9 9
Buthidaung 106,815 5.12 27,219 0.53 392.4 4
Maungdaw 80,348 3.85 16,889 0.33 475.7 6
Pauktaw 33,907 1.62 75,096 1.47 45.15 5
Kawkareik 30,867 1.48 70,417 1.38 43.83 2
Lashio 29,963 1.43 132,229 2.6 22.66 1
Kyaikmaraw 28,590 1.37 45,633 0.9 62.65 1

107 townships have been reached by food security activities in the first three-quarters of 2021. This is less than a third of the 330 townships in the country.

1.4 Locations

Partners have responded in a total of 1563across the country, with the vast majority of locations only having only one partner operating in them. Of the 5776 rows reported in the 5Ws, only 156 did not have any location reported.

Locations are classified into three groups – camps, industrial zones and villages/towns/wards:

Summary of location types
location_type locations townships beneficiaries pc_of_ben avg_ben_per_loc
village_ward_town 1,157 90 1,422,282 81.42 1,229
camp 421 38 316,648 18.13 752
industrial_zone 5 2 7,870 0.45 1,574

The vast majority of locations are served by only one partner. Below are a series of histograms showing the variation in the number of beneficiaries by location, split by number of partners in each location:

The more partners operating in a given location, the higher the average number of beneficiaries; however, it should be noted that these multi-sector locations are comparatively rare:

summarise() has grouped output by ‘location’. You can override using the .groups argument.

partners locations avg_beneficiaries
one_partner 1,496 182
two_partners 61 676
three_partners 11 859

2. Activities and modalities

2.1 Progress by activity

Partners reported their achievements across 8 5W activities. It is interesting to note that almost all the beneficiaries monthly cash transfers were established very early on (or had been established prior to 2021), with new beneficiaries being added very incrementally throughout the year. This speaks to one of the difficulties of interpreting this data – that these patterns are more reflective of partners’ reporting behaviours rather than they are of changes in the field. For instance – was there truly a massive leap in techical training in September, or did a partner report all their achievements at once? Nevertheless, this section will explore the data as it exists to understand what meaningful analysis can be drawn from it.

2.1 Delivery modalilties

Cash is the preferred delivery modality for four out of the nine activities under the Food Security Cluster, followed by “in-kind”, which is the preferred modality in three. However, the in-kind modality has the highest reach, given the especially large beneficiary numbers originating from the provision of monthly food baskets.

It must be noted, however, that a key piece of missing information not currently captured by the 5W template is the duration of these activities – the number of months a monthly food basket is provided cannot be reliably calculated from the data we currently have on hand. We also note several misclassifications – small portions of monthly cash transfers have been coded as in-kind and there are in-kind food baskets coded as hybrid. It might also be worth considering the distinction between “support for income-generating activities” and the “provision of technical training” as service delivery and support are heavily present in both.

summarise() has grouped output by ‘delivery_modality’. You can override using the .groups argument.

Delivery modalities by frequency
delivery_modality First Monthly One-off Other NA Total pc_of_Total
In-kind 303,595 73,665 291,175 1,063,779 40,697 1,772,911 84.9
Cash 894 202,556 64,535 2,973 228 271,186 12.99
Hybrid (In-kind & Cash) NA 11,026 2,488 10,503 NA 24,017 1.15
Service delivery/support NA 2,072 6,040 4,620 NA 12,732 0.61
Voucher NA NA 2,519 4,777 NA 7,296 0.35
Total 304,489 289,319 366,757 1,086,652 40,925 2,088,142 100

In-kind support was by far the most common delivery modality, with 85% of unique beneficiaries receiving support through that means. 13% of beneficiaries were reached by cash transfers. I believe the “other” frequency should be dropped as an option in the 5W template and replaced with more specific options as it is unclear if it refers to interventions that repeat more frequently than once a month or less. It might also be that partners are selecting “other” instead of leaving the field blank. It might be possible to backfill most the the “other” values from the beneficiaries_recurrency column – this will be explore further in the section on beneficiaries.

2.2 Value of intervention packages per household

We note that the most common transfer values – in terms of beneficiaries reached – are between USD 10 and USD 20, though it should be noted – and can be more clearly seen from the table below, a not insignifcant number of beneficiaries were reached by cash transfer interventions valued at more than USD 100 per household.

Cash transfer, hybrid and voucher values per household by frequency of transfer (USD)
transfer_value First Monthly One-off Other Total pc_of_Total
below_$10 185 30,682 2,126 9,543 42,536 14.82
$10_$20 241 122,979 8,002 502 131,724 45.9
$20_$40 242 11,335 13,756 1,881 27,214 9.48
$40_$60 226 29,536 12,850 188 42,800 14.91
$60_$100 NA 9,826 4,850 4,912 19,588 6.83
$100_$200 NA 413 14,255 789 15,457 5.39
above_$200 NA 23 7,204 438 7,665 2.67

Next, let us take a look at household package values by activity type:

An avenue to explore here would be the provision of monthly cash transfers – this activity has a very clear peak at $10-$20. A closer look at the data reveals this almost entirely due 122,854 beneficiaries who received monthly transfers of USD 10.50 per household; it is unclear whether USD 10.50 per household would be sufficient to cover their monthly food needs – we should cross-reference this with the calculations for minimum expenditure baskets – but it certainly is doubtful. Perhaps this type of relatively low-value transfer should be reclassified as a supplementary intervention not meant to cover a household food security needs. 7 partners currently provide this type of monthly transfer – Save the Children, WFP, Myanmar Heart Organisation, People for People, Plan International, World Vision Myanmar and Karuna Mission Social Solidarity; we should follow up with them to understand if this sum (equivalent to MMK 15,000) is truly meant to cover monthly food expenditures.

The two peaks in “support for income-generating activities” ($10-$20 and above_$200) are an order of magnitude apart – it not inconceivable that they should be split into two separate activities.

Some partners have also reported the value of the food baskets they are distributed; however, these only represent a small fraction of the total (less than 1%, by beneficiaries) and it would be much more preferable to collect the actual contents of these food baskets for analysis than use the data in the 5Ws.

3. Partners

Partners fairly evenly split themselves between HRP indicators, with 29 contributing towards food and cash assistance and 28 contributing towards agriculture and other livelihood support. As a reference, 28 partners have reached less than 10,000 unique beneficiaries and the median unique beneficiaries reached by partners is 4,697. Below are the top 10 partners by HRP indicator.

Top 10 partners by beneficiaries reached, by HRP indicator
Partners HRP indicator 1 1. Number of people who received food and/or cash assistance Partners HRP indicator 2 2. Number of people who received agriculture and other livelihood support
Open Data Myanmar (ODM) 304,919 Center for Social Integrity (CSI) 28,725
MRCS 263,005 Action Contre la Faim 19,109
Zigway 223,478 Action for Green Earth 16,037
Hlaingthayar Development Network 189,701 World Vision Myanmar 15,303
World Vision Myanmar 168,698 Myanmar Heart Development Organization 9,867
Urban Strength (US) 128,878 WFP 7,691
WFP 105,984 Save the Children 7,543
Hlaingthayar Youth Network 96,145 Phyu Sin Saydanar Action Group 6,052
Action for Green Earth 67,578 BRAC Myanmar 5,162
Myanmar Heart Development Organization 63,838 MRCS 5,051

Distribution of partners by beneficiaries and geographic reach

mouse over for details

Whilst there is quite a bit of variation in the number of beneficiaries reached, we can see that partners’ geographic footprints are – on the whole – quite limited. Only 4 out of 47 partners have a presence in more than 10 townships, with only 10 being present in more than 5. 79% of our partners (clustered along the bottom of the chart) are present in 5 or less townships. If the response is truly meant to be countrywide, it is imperative to understand what would incentivise partners to expand their footprints.

Map of number of partners and people in need by state/region

There are 58 combinations between reporting organisations and implementing partners, 19 of which are instances where the reporting organisation and the implementing partner and the same organisation; once these 19 are filtered out, all the remaining implementing partners correspond to just 10 reporting organisations:

Number of implementing partners by reporting organisation
reporting_organization implementing_partners
WFP 21
Save the Children 4
FAO 3
Finn Church Aid 3
Mercy Corps 2
Trocaire 2
AVSI 1
Danish Refugee Council 1
Helvetas 1
Oxfam 1
Beneficiaries by implmenting partner type
implementing_partner_type beneficiaries townships
INGO 1,469,735 55
NNGO 2,779,172 60
UN 1,245,381 52

Beneficiaries

summarise() has grouped output by ‘state’. You can override using the .groups argument.

Percentage of beneficiaries by type, by state/region
state Host/local Community Internally Displaced Returnees Rakhine stateless beneficiaries
Ayeyarwady 100 NA NA NA 55,276
Bago (East) NA 100 NA NA 4,312
Chin 9.225 90.77 NA NA 13,550
Kachin 6.486 91.8 1.714 NA 87,452
Kayah 45.89 54.11 NA NA 15,920
Kayin 89.99 10.01 NA NA 46,932
Magway 100 NA NA NA 1,695
Mandalay 100 NA NA NA 24,829
Mon 91.68 6.524 1.795 NA 43,442
Rakhine 19.17 12.5 NA 68.33 430,247
Sagaing 100 NA NA NA 8,090
Shan (East) 100 NA NA NA 510
Shan (North) 25.69 74.31 NA NA 71,677
Shan (South) 100 NA NA NA 9,304
Yangon 100 NA NA NA 1,274,906
Total 75.27 10.54 0.1091 14.08 NA

The states and sub-regions in which we are working the most with IDPs are Bago (East), Kachin, Chin, Shan (North) and Kayah. Overall, 75% of beneficiaries are from the host/local community, 14% are stateless persons from Rakhine and 11% are IDPs.

## # A tibble: 3 x 3
## # Groups:   beneficiaries_recurrency [3]
##   beneficiaries_recurrency frequency beneficiaries
##   <chr>                    <chr>             <dbl>
## 1 First                    Other           1044698
## 2 One-off                  Other             41974
## 3 Recurrent                Other            367867

---
title: "Initial report on the Myanmar Food Security 5Ws"
author: "Sean Ng"
date: "24/11/2021"
output: 
  html_document:
    code_download: true
    theme: readable
    toc: true
    toc_depth: 4
    toc_float: true
    number_sections: false
    collapsed: false
    
---

<style>
    body .main-container {
        max-width: 1280px;
    }
</style>

```{r setup, include=FALSE}
knitr::opts_chunk$set(echo = FALSE, fig.width=9, message = FALSE, warning=FALSE)
library(tidyverse)
library(readxl)
library(lubridate)
library(stringi)
library(pander)
library(janitor)
library(fuzzyjoin)
library(scales)
library(magrittr)
library(sf)
library(bookdown)
library(data.table)
library(ggsflabel)
library(patchwork)
library(plotly)

theme_set(theme_light())

# disabling scientific notation
options(scipen = 100)

# pander tables all in one row
panderOptions('table.split.table', Inf)

# pander thousands separator
panderOptions("big.mark", ",")

`%out%` <- Negate(`%in%`)

# function for transposing df
transpose_df <- function(df) {
  t_df <- data.table::transpose(df)
  colnames(t_df) <- rownames(df)
  rownames(t_df) <- colnames(df)
  t_df <- t_df %>%
    tibble::rownames_to_column(.data = .) %>%
    tibble::as_tibble(.)
  return(t_df)
}

# function beneficiary summaries
fscben <- function(df, column_var){
  
  column_var <- enquo(column_var)
  
  df %>%
    group_by(!!column_var) %>% # must add bang-bang
    summarise(beneficiaries = sum(beneficiaries)) %>% 
    arrange(desc(beneficiaries))
    
 }

```

### datasets

```{r datasets, include=FALSE}

# indicator guide for vulmmr
indicator_guide <- read_excel("Datasets_Vulnerability_Analysis_in_Myanmar_09Jul2018 (1).xlsx",
           skip = 1) %>% 
  slice(1:3) %>% 
  janitor::clean_names() %>% 
  transpose_df() %>% 
  rename(indicator = rowname, 
         age_group = `1`,
         category = `2`, 
         source = `3`) %>% 
  slice(-1)

# reading in vulnerability dataset
vulmmr <- read_excel("Datasets_Vulnerability_Analysis_in_Myanmar_09Jul2018 (1).xlsx",
           skip = 1) %>% 
  slice(-c(1:3)) %>% 
  clean_names() %>% 
  select(-label) %>% 
  mutate_at(vars(number_of_village_tracts:wb_wealth_rank), as.numeric) %>% 
  mutate_at(vars(disasters_impacted_by_nargis_2008:acled_2015_2016_data_exists), as.logical) %>% 
  mutate_at(vars(conflict_2015_2016_number_of_battles:corrected_conflict_index_garry), as.numeric) %>% 
  select(-starts_with("x")) %>% 
  select(-c(private_sector_development_2014_2015, protection_2010_2015, shelter_2010_2015, wash_2010_2015)) 

# reading in townships from geoadmins 
townships <- read_excel("FSC 5W 2021 - GEOADMINS_final 19.xlsx",
           sheet = "GEOADMINS") %>% 
  clean_names() %>% 
  select(admin1pcode_4:admin3pcode) %>% 
  rename(admin1_pcode = admin1pcode_4,
         admin3_pcode = admin3pcode,
         state_name   = state_5,
         township_name  = county) %>% 
  remove_empty()

# locations dataset 
locations <- bind_rows(
  
  read_excel("FSC 5W 2021 - GEOADMINS_final 19.xlsx", # payams 
             sheet = "GEOADMINS") %>% 
    clean_names() %>% 
    select(state_name:payam_code) %>% 
    rename(admin1_pcode = state_code_12,
           township_name = county_name, 
           admin3_pcode = county_code,
           location = payam_name) %>%
    remove_empty() %>% 
    mutate(location_type = paste0("payam")),
  
  read_excel("FSC 5W 2021 - GEOADMINS_final 19.xlsx", # camps
             sheet = "GEOADMINS") %>% 
    clean_names() %>% 
    select(county_name1:p_code_camp) %>% 
    rename(township_name = county_name1,
           admin3_pcode = state_code_23,
           location = camps, 
           camp_pcode = p_code_camp) %>% 
    remove_empty() %>% 
    mutate(location_type = paste0("camp")) %>% 
    left_join(townships %>% select(state_name, admin1_pcode, admin3_pcode), 
              by = c("admin3_pcode")) %>% 
    relocate(admin1_pcode) %>% 
    relocate(state_name),
  
  read_excel("FSC 5W 2021 - GEOADMINS_final 19.xlsx", # industrial zones
             sheet = "GEOADMINS") %>% 
    clean_names() %>%
    select(state_28:industrial_zones) %>% 
    rename(state_name = state_28, 
           admin1_pcode = admin1pcode_29,
           location = industrial_zones) %>%
    remove_empty() %>% 
    regex_left_join(townships %>% select(township_name, admin3_pcode),
                    by = c("location" = "township_name")) %>% 
    # replacing the NAs with 0s so the filter doesn't drop them 
    replace_na(list(township_name = 0, admin3_pcode = 0, admin1_pcode = 0)) %>%
    filter(admin3_pcode != "MMR013040") %>% # removing all the matches between Hlaingtharya and Hlaing
    filter(admin3_pcode != "MMR011006") %>% # removing all the matches between Yenangyaung and Ye
    mutate(location_type = paste0("industrial_zone"))
  
)%>%
  mutate(location_code = case_when(location_type == "camp" ~ camp_pcode,
                                   location_type == "payam" ~ payam_code,
                                   location_type == "industrial_zone" ~ NA_character_)) %>%
  mutate(locations_fuzzy = str_replace_all(location, "[[:punct:]]", ""))

# reading in 5ws
fsc <- read_excel(
  "FSC 5W 2021 - GEOADMINS_final19_(included All IP Reports)_Jan to Sep 2021_IM Combined_Final.xlsx",
                  sheet = "FSC 5W Activites",
                  skip = 5) %>% 
  janitor::clean_names() %>% 
  select(month_of_implementation:hrp_version) %>% 
  rename_all(~str_replace_all(., "^number_of_", "")) %>%
  rename_all(~str_replace_all(., "^number_", "")) %>% 
  rename(admin4_pcode = admin3_pcode, 
         admin3_pcode = admin2_pcode,
         beneficiaries = reached_beneficiaries,
         households = reached_households,
         beneficiary_type = beneficiaries_type) %>% 
  mutate(industrial_zones = replace(industrial_zones, industrial_zones == "No", NA),
         frequency = replace(frequency, frequency == "N/A", NA)) %>% 
  mutate(location = case_when(camp != "NA" ~ camp,
                              industrial_zones != "NA" ~ industrial_zones,
                              village_ward_town != "NA" ~ village_ward_town)) %>% 
  mutate(location_type = case_when(camp != "NA" ~ "camp",
                              industrial_zones != "NA" ~ "industrial_zone",
                              village_ward_town != "NA" ~ "village_ward_town")) %>%
  mutate(locations_fuzzy = str_replace_all(location, "[[:punct:]]", " ")) %>% 
  mutate(total_value_mmk = value_per_household * households) %>% 
  mutate(date = my(month_of_implementation)) %>% 
  mutate(u_ben = ifelse(unique_beneficiaries == "Yes", beneficiaries, 0)) %>% 
  mutate(state = as.character(fct_recode(state, 
                            "Kachin" = "kachin"))) %>% 
  mutate(mmk_hhd_bin = case_when(value_per_household < 10000 ~ "below_10k",
                             value_per_household >= 10000 & value_per_household <= 20000 ~ "10k_20k",
                             value_per_household > 20000 & value_per_household <= 50000 ~ "20k_50k",
                             value_per_household > 50000 & value_per_household <= 70000 ~ "50k_70k",
                             value_per_household > 70000 & value_per_household < 100000 ~ "70k_100k",
                             value_per_household >= 100000 & value_per_household < 200000 ~ "100k_200k",
                             value_per_household >= 200000 & value_per_household <= 300000 ~ "200k_300k",
                             value_per_household > 300000 ~ "above_300k",
                             TRUE ~ NA_character_),
         mmk_hhd_bin = fct_relevel(mmk_hhd_bin, c("less_than_10k", "10k_20k","20k_50k", "50k_70k", "70k_100k", "100k_200k",
                                          "200k_300k","more_than_300k")),
         frequency = recode(frequency, "monthly" = "Monthly")) %>%
  mutate(usd_hhd_bin = 
           case_when(value_per_household_usd < 10 ~ "below_$10",
                     value_per_household_usd >= 10 & value_per_household_usd < 20 ~ "$10_$20",
                     value_per_household_usd >= 20 & value_per_household_usd < 40 ~ "$20_$40",
                     value_per_household_usd >= 40 & value_per_household_usd < 60 ~ "$40_$60",
                     value_per_household_usd >= 60 & value_per_household_usd < 100 ~ "$60_$100",
                     value_per_household_usd >= 100 & value_per_household_usd < 200 ~ "$100_$200",
                     value_per_household_usd >= 200 ~ "above_$200",
                     TRUE ~ NA_character_),
         usd_hhd_bin = fct_relevel(usd_hhd_bin, c("below_$10", "$10_$20", "$20_$40", "$40_$60", 
                                                  "$60_$100", "$100_$200", "above_$200"))) %>% 
  mutate(hrp_indicator =
          recode(hrp_indicator,
          "Number of people who received food and/or cash assistance" = 
            "1. Number of people who received food and/or cash assistance",
          "Number of people who received agriculture and other livelihood support, contributing to household food security" =
            "2. Number of people who received agriculture and other livelihood support")) %>% 
  mutate(beneficiary_type = str_trim(beneficiary_type)) %>% 
  mutate(beneficiary_type = as.character(fct_recode(beneficiary_type, 
               "Rakhine stateless" = "Non-displaced stateless people in Rakhine")))
  

# ben dataset -- tidy fromat 5Ws for beneficiaries 
ben <- fsc %>% 
  filter(unique_beneficiaries == "Yes") %>%  
  select(date,
         implementing_partners, implementing_partner_type,
         state, township, village_ward_town, location, location_type, admin1_pcode, admin3_pcode,
         activity, activity_status, hrp_indicator, beneficiary_type, 
         child_male, child_female, adult_male, adult_female, elderly_male, elderly_female) %>% 
  pivot_longer(cols = child_male:elderly_female, 
               names_to = "disaggregation", values_to = "beneficiaries", values_drop_na = TRUE)
 

# reading in pin and targets
pin <- read_excel("PIN calculation Food Security Cluster_Township Breakdown.xlsx",
           sheet = "Food Sec PiN with IDPs", 
           skip = 2) %>% 
  clean_names() %>% 
  select(-c(x15, x16, x17, x18)) %>% 
  slice(1:346) %>% 
  fill(region) %>% 
  rename(state = region,
         idps = id_ps, 
         pop_minus_idps = population_minus_id_ps, 
         total_pin = vulnerable_food_insecure_people_id_ps) %>%  
  filter(township != "Total") %>%  
  mutate_at(vars(pop_minus_idps:moderately_severely), ~ as.numeric(.)) %>% 
  left_join(townships, by = c("township" = "township_name")) %>% 
  replace(is.na(.), 0)  %>% 
  select(-state) %>%  
  relocate(admin3_pcode) %>% relocate(state = state_name) %>% relocate(admin1_pcode) %>% 
  mutate(pc_vul = total_pin / total_pop,
         total_pin = round(total_pin, digits = 0))

# shapefiles
pcode3_shape <- st_read("./mmr_polbnda_adm3_mimu_250k/mmr_polbnda_adm3_mimu_250k.shp", quiet = TRUE) %>% 
  rename(state = ST, 
         admin1_pcode = ST_PCODE,
         township = TS,
         admin3_pcode = TS_PCODE)

pcode1_shape <- st_read("./mmr_polbnda2_adm1_mimu_250k/mmr_polbnda2_adm1_mimu_250k.shp", quiet = TRUE) %>% 
  rename(state = ST, 
         admin1_pcode = ST_PCODE)

# for relevelling -- this is in order of beneficiaries
sr_ord <- c("Yangon", "Rakhine","Kachin", "Ayeyarwady", "Kayin",  
  "Mon", "Mandalay", "Kayah", "Chin", "Sagaing", "Magway", 
  "Bago", "Nay Pyi Taw", "Shan", "Tanintharyi")
```


## 1. Analysis by geography

### 1.1 Comparing beneficiaries reached and PIN by state and region 

```{r}

pin %>% 
  left_join(ben %>% 
              group_by(admin3_pcode) %>% 
              summarise(beneficiaries = sum(beneficiaries))) %>% 
  mutate(beneficiaries = ifelse(is.na(beneficiaries), 0, beneficiaries)) %>% 
  group_by(state) %>% 
  summarise(beneficiaries = sum(beneficiaries), 
            total_pin = sum(total_pin)) %>% 
  pivot_longer(-state, names_to = "type", values_to = "value") %>% 
  ggplot(aes(x = fct_relevel(state, sr_ord), y = value, fill = type)) +
  geom_col(position = "dodge") +
  theme(axis.text.x = element_text(vjust = 0.4, angle = 70)) +
  theme(legend.title = element_blank()) +
  labs(x = "",
       y = "", 
       title = "Food security beneficiaries and people in need") +
   scale_y_continuous(breaks = seq(0, 2000000, by = 200000), labels = comma)

  
```

The PIN figures originated from the WFP township-level calculations for the FSC based on the combination of food insecure persons and IDPs. 


> Currently the beneficiaries reached by the Food Security Cluster far exceed the figures for People in Need established in 2021. 2,088,142 have been reached throughout the first three quarters of 2021; this is 71% of the cluster PIN; however, as we can see, the response has been heavily skewed towards Yangon and Rakhine. 


### 1.2 Beneficiaries and PIN by state and region 

```{r}
pin %>% 
  left_join(ben %>% 
              group_by(admin3_pcode) %>% 
              summarise(beneficiaries = sum(beneficiaries))) %>% 
  mutate(beneficiaries = ifelse(is.na(beneficiaries), 0, beneficiaries)) %>% 
  group_by(state) %>% 
  summarise(beneficiaries = sum(beneficiaries), 
            PIN = sum(total_pin)) %>% 
  mutate(`%_of_ben` = round(beneficiaries / sum(beneficiaries) * 100, digits = 2),
         `%_of_PIN` = round(PIN / sum(PIN) * 100, digits = 2),
         `%_PIN_reached` = ifelse(is.infinite(beneficiaries / PIN * 100), NA_real_, beneficiaries / PIN * 100),
         `%_PIN_reached` = round(`%_PIN_reached`, digits = 2))  %>% 
  relocate(`%_of_ben`, .after = beneficiaries) %>% 
  arrange(desc(`%_PIN_reached`)) %>% 
  pander(caption = "Beneficiaries reached and PIN by state/region")

```

In general, there is large mismatch between a state's share of beneficiaries and its share of the PIN -- notably, Yangon constitutes 61% of all beneficiaries but only 15% of the nationwide PIN. Although Yangon has the highest share of people in need, it should also be stressed that the percentage of it's population that is vulnerable -- that is, either food insecure or internally displaced -- is one of the lowest in the country, at 22%, with only Magway, Sagaing and Mandalay having lower percentages: 

```{r}
pin %>% 
  group_by(state) %>% 
  filter(state != "Nay Pyi Taw") %>% 
  summarise(total_pin = round(sum(total_pin)),
            total_pop = sum(total_pop)) %>% 
  mutate(`vulnerable%` = round(total_pin / total_pop * 100, digits = 2),
         state = reorder(state, -`vulnerable%`))  %>% 
  ggplot(aes(x = state, y = total_pin, fill = `vulnerable%`)) +
  geom_col() +
  geom_text(aes(label = `vulnerable%`), size = 2.5, vjust = -0.5) +
  theme(axis.text.x = element_text(angle = 70, vjust = 0.5, hjust = 0.6)) +
  labs(x = "",
       y = "Number of people in need", 
       title = "PIN and incidence of vulnerabilty by state and region",
       subtitle = "Vulnerability is defined here as the proportion of a population who are food insecure or are IDPs") +
  scale_y_continuous(breaks = seq(0, 2000000, by = 200000), labels = comma) +
  scale_fill_continuous(trans = "reverse")
```

Vulnerability here has been defined as the proportion of the population who are 

### 1.3 Township-level

Just as the response has been very skewed at the state and region level, the same is true at the township level. These 10 townships below are where 80% of all beneficiaries have been reached despite only constituting 15% of the PIN -- in particular, Dagon Myothit (Seikkan) and Hlaingtharya have beneficiary figures that are 633% and 430% of their PIN respectively. For reference, the median percentage of people in need covered per township in the areas we work in is 7%.  


```{r}
ben %>% 
  group_by(township) %>% 
  summarise(beneficiaries = sum(beneficiaries), 
            partners = n_distinct(implementing_partners)) %>% 
  left_join(pin %>% select(township, pin = total_pin), by = "township") %>% 
  mutate(pc_of_total = round(beneficiaries / sum(beneficiaries) * 100, digits = 2),
         pc_of_pin = round(pin / sum(pin, na.rm = TRUE) * 100, digits = 2),
         pc_reached = round(beneficiaries / pin * 100, digits = 2)) %>% 
  relocate(pc_of_total, .after = beneficiaries) %>% 
  relocate(partners, .after = pc_reached) %>% 
  arrange(desc(pc_of_total)) %>% 
  head(10) %>% 
  pander(caption = "Top 10 townships by beneficiaries reached")

 
```

`r ben %>% select(township) %>% distinct() %>% nrow()` townships have been reached by food security activities in the first three-quarters of 2021. This is less than a third of the 330 townships in the country. 

### 1.4 Locations

Partners have responded in a total of `r ben %>% select(location) %>% distinct() %>% nrow()`across the country, with the vast majority of locations only having only one partner operating in them. Of the `r fsc %>% nrow()` rows reported in the 5Ws, only `r sum(is.na(fsc$location))` did not have any location reported. 

Locations are classified into three groups -- camps, industrial zones and villages/towns/wards: 

```{r}
ben %>% 
  filter(!is.na(location)) %>% 
  group_by(location_type) %>% 
  summarise(locations = n_distinct(location),
            townships = n_distinct(township),
            beneficiaries = sum(beneficiaries)) %>% 
  mutate(pc_of_ben = round(beneficiaries / sum(beneficiaries) * 100, digits = 2), 
         avg_ben_per_loc = round(beneficiaries / locations, digits = 0)) %>% 
  arrange(desc(beneficiaries)) %>% 
  pander(caption = "Summary of location types")
```

The vast majority of locations are served by only one partner. Below are a series of histograms showing the variation in the number of beneficiaries by location, split by number of partners in each location:

```{r}

ben %>% 
  filter(!is.na(location)) %>% 
  group_by(location, township) %>%  
  summarise(beneficiaries = sum(beneficiaries), 
            partners = n_distinct(implementing_partners)) %>% 
  arrange(desc(partners)) %>% 
  ggplot(aes(x = beneficiaries)) +
  geom_histogram(binwidth = 0.1) +
  scale_x_log10() +
  facet_wrap(~ partners) +
  labs(y = "number of locations",
       x = "beneficiaries per location", 
       title = "Histograms of beneficiaries by location",
       subtitle = "Faceted by number of partners per location")

```

The more partners operating in a given location, the higher the average number of beneficiaries; however, it should be noted that these multi-sector locations are comparatively rare:

```{r}
ben %>% 
  filter(!is.na(location)) %>% 
  group_by(location, township) %>%  
  summarise(beneficiaries = sum(beneficiaries), 
            partners = n_distinct(implementing_partners)) %>% 
  group_by(partners) %>% 
  summarise(locations = sum(n_distinct(location)),
            avg_beneficiaries = median(beneficiaries)) %>%
  mutate(partners = recode(partners, `1` = "one_partner",
                           `2` = "two_partners",
                           `3` = "three_partners")) %>% 
 pander()

```

## 2. Activities and modalities

### 2.1 Progress by activity

```{r}
ben %>% 
  group_by(activity) %>% 
  arrange(date) %>% 
  mutate(cum_ben = cumsum(beneficiaries)) %>% 
   mutate(activity = substr(activity, 0, 55)) %>% 
  ggplot(aes(x = date, y = cum_ben, colour = activity)) +
  geom_line() +
  scale_x_date(date_breaks = "1 month", date_labels = "%b") +
  scale_y_continuous(labels = comma) +
  facet_wrap(~ activity, scales = "free_y") +
  theme(legend.position = "none") +
  labs(x = "", 
       y = "cumulative beneficiaries", 
       title = "Monthly progress by activity, 2021 Q1-Q3") + 
  theme(plot.title = element_text(size = 12))
```

Partners reported their achievements across 8 5W activities. It is interesting to note that almost all the beneficiaries monthly cash transfers were established very early on (or had been established prior to 2021), with new beneficiaries being added very incrementally throughout the year. This speaks to one of the difficulties of interpreting this data -- that these patterns are more reflective of partners' reporting behaviours rather than they are of changes in the field. For instance -- was there truly a massive leap in techical training in September, or did a partner report all their achievements at once? Nevertheless, this section will explore the data as it exists to understand what meaningful analysis can be drawn from it. 

### 2.1 Delivery modalilties 

```{r}
fsc %>% 
  filter(unique_beneficiaries == "Yes" & !is.na(delivery_modality)) %>% 
  group_by(delivery_modality, activity) %>% 
  summarise(beneficiaries = sum(beneficiaries)) %>%
  mutate(activity = substr(activity, 0, 72),
         delivery_modality = recode(delivery_modality, 
                                    "Hybrid (In-kind & Cash)" = "Hybrid",
                                    "Service delivery/support" = "Services/support")) %>% 
  ggplot(aes(x = delivery_modality, y = beneficiaries, fill = activity)) +
  geom_col() +
  scale_y_continuous(labels = comma) +
  labs(x = "") +
  theme(legend.position = "none", 
        axis.text.x = element_text(angle = 40, hjust = 0.5, vjust = 0.5)) +
  facet_wrap(~ activity, scales = "free_y")
  
```

Cash is the preferred delivery modality for four out of the nine activities under the Food Security Cluster, followed by "in-kind", which is the preferred modality in three. However, the in-kind modality has the highest reach, given the especially large beneficiary numbers originating from the provision of monthly food baskets. 

It must be noted, however, that a key piece of missing information not currently captured by the 5W template is the duration of these activities -- the number of months a monthly food basket is provided cannot be reliably calculated from the data we currently have on hand. We also note several misclassifications -- small portions of monthly cash transfers have been coded as in-kind and there are in-kind food baskets coded as hybrid. It might also be worth considering the distinction between "support for income-generating activities" and the "provision of technical training" as service delivery and support are heavily present in both. 

```{r}
fsc %>% 
  filter(unique_beneficiaries == "Yes") %>% 
  group_by(delivery_modality, frequency) %>% 
  summarise(beneficiaries = sum(beneficiaries)) %>% 
  filter(beneficiaries > 0) %>% 
  pivot_wider(names_from = frequency, values_from = beneficiaries) %>% 
  adorn_totals("col", na.rm = TRUE) %>% 
  mutate(pc_of_Total = round(Total / 2088142 * 100, digits = 2)) %>% 
  arrange(desc(Total)) %>% 
  adorn_totals("row", na.rm = TRUE) %>% 
  pander(caption = "Delivery modalities by frequency")

```

In-kind support was by far the most common delivery modality, with 85% of unique beneficiaries receiving support through that means. 13% of beneficiaries were reached by cash transfers. I believe the "other" frequency should be dropped as an option in the 5W template and replaced with more specific options as it is unclear if it refers to interventions that repeat more frequently than once a month or less. It might also be that partners are selecting "other" instead of leaving the field blank. It might be possible to backfill most the the "other" values from the `beneficiaries_recurrency` column -- this will be explore further in the section on beneficiaries. 

### 2.2 Value of intervention packages per household 

```{r}
fsc %>% 
  filter(unique_beneficiaries == "Yes" & !is.na(usd_hhd_bin)) %>%
  group_by(usd_hhd_bin) %>%  
  summarise(beneficiaries = sum(beneficiaries)) %>% 
  ggplot(aes(x = usd_hhd_bin, y = beneficiaries)) +
  geom_col() +
  labs(x = "USD value of cash transfer per household",
       y = "Beneficiaries",
       title = "Number of beneficiaries per value of cash transfer value per household")
```

We note that the most common transfer values -- in terms of beneficiaries reached -- are between USD 10 and USD 20, though it should be noted -- and can be more clearly seen from the table below, a not insignifcant number of beneficiaries were reached by cash transfer interventions valued at more than USD 100 per household. 

```{r}
fsc %>%  
  filter(!is.na(usd_hhd_bin) & unique_beneficiaries == "Yes") %>% 
  filter(delivery_modality %in% c("Cash", "Hybrid (In-kind & Cash)", "Voucher")) %>% 
  count(usd_hhd_bin,frequency, wt = beneficiaries) %>%
  pivot_wider(names_from = frequency, values_from = n) %>% 
  rename(transfer_value = usd_hhd_bin) %>%
  relocate(First, .after = transfer_value) %>% 
  select(-`NA`) %>% 
  adorn_totals("col", na.rm = TRUE) %>% 
  mutate(pc_of_Total = round(Total / sum(Total) * 100, digits = 2)) %>% 
  pander(caption = "Cash transfer, hybrid and voucher values per household by frequency of transfer (USD)")   
```

Next, let us take a look at household package values by activity type:

```{r}
fsc %>% 
  filter(!is.na(usd_hhd_bin) & unique_beneficiaries == "Yes") %>%
  group_by(activity, usd_hhd_bin) %>% 
  summarise(beneficiaries = sum(beneficiaries)) %>% 
  mutate(activity = substr(activity, 0, 72)) %>% 
  ggplot(aes(x = usd_hhd_bin, y = beneficiaries, fill = activity)) +
  geom_col() +
  scale_y_continuous(labels = comma) +
  labs(x = "") +
  theme(legend.position = "none") +
  facet_wrap(~ activity, scales = "free_y") + 
  labs(title = "Variation in the  per household values of intervention packages in USD",
       subtitle = "Faceted by activity")

```

An avenue to explore here would be the provision of monthly cash transfers -- this activity has a very clear peak at `$10-$20`. A closer look at the data reveals this almost entirely due 122,854 beneficiaries who received monthly transfers of USD 10.50 per household; it is unclear whether USD 10.50 per household would be sufficient to cover their monthly food needs -- we should cross-reference this with the calculations for minimum expenditure baskets -- but it certainly is doubtful. Perhaps this type of relatively low-value transfer should be reclassified as a supplementary intervention not meant to cover a household food security needs. 7 partners currently provide this type of monthly transfer -- Save the Children, WFP, Myanmar Heart Organisation, People for People, Plan International, World Vision Myanmar and Karuna Mission Social Solidarity; we should follow up with them to understand if this sum (equivalent to MMK 15,000) is truly meant to cover monthly food expenditures. 

The two peaks in "support for income-generating activities" (`$10-$20` and `above_$200`) are an order of magnitude apart -- it not inconceivable that they should be split into two separate activities. 

Some partners have also reported the value of the food baskets they are distributed; however, these only represent a small fraction of the total (less than 1%, by beneficiaries) and it would be much more preferable to collect the actual contents of these food baskets for analysis than use the data in the 5Ws. 


## 3. Partners

Partners fairly evenly split themselves between HRP indicators, with 29 contributing towards food and cash assistance and 28 contributing towards agriculture and other livelihood support. As a reference, 28 partners have reached less than 10,000 unique beneficiaries and the median unique beneficiaries reached by partners is 4,697. Below are the top 10 partners by HRP indicator. 

```{r}

cbind(
  
  ben %>% 
    filter(hrp_indicator == "1. Number of people who received food and/or cash assistance") %>% 
    group_by(implementing_partners) %>% 
    summarise(beneficiaries = sum(beneficiaries)) %>% 
    arrange(desc(beneficiaries)) %>% 
    rename(`1. Number of people who received food and/or cash assistance` = beneficiaries,
           `Partners HRP indicator 1` = implementing_partners) %>% 
    head(10),
  
  ben %>% 
    filter(hrp_indicator == "2. Number of people who received agriculture and other livelihood support") %>% 
    group_by(implementing_partners) %>% 
    summarise(beneficiaries = sum(beneficiaries)) %>% 
    arrange(desc(beneficiaries)) %>% 
    rename(`2. Number of people who received agriculture and other livelihood support` = beneficiaries,
           `Partners HRP indicator 2` = implementing_partners) %>% 
    head(10)
  
) %>% 
  add_column(` ` = " ") %>% 
  relocate(` `, .after = `1. Number of people who received food and/or cash assistance`) %>% 
  pander(caption = "Top 10 partners by beneficiaries reached, by HRP indicator")

```

### Distribution of partners by beneficiaries and geographic reach 
_mouse over for details_

Whilst there is quite a bit of variation in the number of beneficiaries reached, we can see that partners' geographic footprints are -- on the whole -- quite limited. Only 4 out of 47 partners have a presence in more than 10 townships, with only 10 being present in more than 5. 79% of our partners (clustered along the bottom of the chart) are present in 5 or less townships. If the response is truly meant to be countrywide, it is imperative to understand what would incentivise partners to expand their footprints.

```{r}
partner_scatter <- ben %>% 
  group_by(implementing_partners) %>% 
  summarise(states = n_distinct(admin1_pcode),
            townships = n_distinct(admin3_pcode),
            beneficiaries = sum(beneficiaries)) %>% 
  arrange(desc(states)) %>% 
  ggplot(aes(x = beneficiaries, y = townships, text = implementing_partners)) +  
  geom_point(aes(size = beneficiaries)) +
  scale_x_continuous(trans = "log", labels = comma, breaks = c(0, 100, 1000, 10000, 100000, 300000)) +
  scale_y_continuous(breaks = seq(0, 30, 5)) +
  labs(x = "Number of beneficiaries",
       y = "Number of townships",
       title = "Plot of beneficiaries and townships reached, by implementing partner") 
# for some reason, removing this messes with the alignment of the plot

ggplotly(partner_scatter) %>%
  config(displayModeBar = FALSE) %>% 
  layout(title = list(text = paste0("Plot of beneficiaries and townships reached, by implementing partner",
                                    "<br>", 
                                    "<sup>",
                                    "mouse over for details",
                                    "</sup>")))
  
```

### Map of number of partners and people in need by state/region

```{r}

ben %>% 
  group_by(state) %>% 
  summarise(partners = n_distinct(implementing_partners)) %>% 
  right_join(pcode1_shape, by = "state") %>% 
  st_as_sf() %>% 
  ggplot() +
  geom_sf(aes(fill = partners), size = 0.1) +
  geom_sf_text(aes(label = partners), size = 2) +
  scale_fill_gradient(trans = "reverse") +
  theme_void() + 
  theme(legend.text = element_text(size = 3),
        legend.title = element_text(size = 3),
        legend.key.size = unit(0.3, 'cm')) +

pin %>% 
  group_by(state) %>% 
  summarise(PIN = sum(total_pin)) %>% 
  mutate(PIN = round(PIN, digits = 0), 
         PIN = recode(PIN, 
                      '0' = NA_real_)) %>%
  right_join(pcode1_shape, by = "state") %>% 
  st_as_sf() %>% 
  ggplot() +
  geom_sf(aes(fill = PIN), size = 0.1) +
  geom_sf_text_repel(aes(label = scales::comma(PIN)), size = 1.5) +
  scale_fill_gradient(trans = "reverse") +
  theme_void() +
  theme(legend.text = element_text(size = 3),
        legend.title = element_text(size = 3),
        legend.key.size = unit(0.3, 'cm'))


```
There are 58 combinations between reporting organisations and implementing partners, 19 of which are instances where the reporting organisation and the implementing partner and the same organisation; once these 19 are filtered out, all the remaining implementing partners correspond to just 10 reporting organisations:

```{r}
fsc %>% 
  filter(reporting_organization != implementing_partners) %>% 
  group_by(reporting_organization) %>% 
  summarise(implementing_partners = n_distinct(implementing_partners)) %>% 
  arrange(desc(implementing_partners)) %>% 
  pander(caption = 'Number of implementing partners by reporting organisation')
  
```
```{r}
fsc %>% 
  group_by(implementing_partner_type) %>%  
  summarise(beneficiaries = sum(beneficiaries), 
            townships = n_distinct(admin3_pcode)) %>% 
  pander(caption = "Beneficiaries by implmenting partner type")
```





```{r}
vulmmr %>% 
  select(state = state_region_name, adjusted_approximate_vulnerable_population, total_pop_both_sexes) %>% 
  group_by(state) %>%  
  drop_na() %>%
  summarise(vulnerable_pop = sum(adjusted_approximate_vulnerable_population), 
            total_pop = sum(total_pop_both_sexes)) %>% 
  mutate(vulnerable_pc = vulnerable_pop / total_pop) %>% 
  left_join(ben %>%
              group_by(state) %>%
              summarise(beneficiaries = sum(beneficiaries)), by = "state") %>% 
  mutate(beneficiaries = ifelse(!is.na(beneficiaries), beneficiaries, 0)) %>% 
  pivot_longer(cols = c(vulnerable_pop, beneficiaries), names_to = "type", values_to = "value") %>% 
  ggplot(aes(x = fct_relevel(state, sr_ord), y = value, fill = type)) + 
  geom_col(position = "dodge")+
  theme(axis.text.x = element_text(angle = 60, vjust = 0.5, hjust = 0.5)) +
  theme(legend.title = element_blank()) +
  labs(x = "",
       y = "", 
       title = "Food security beneficiaries (5Ws) and vulnerable population (MIMU)") +
  scale_y_continuous(labels = comma)
```


### Beneficiaries 

```{r}
fsc %>% 
  filter(!is.na(beneficiary_type) & unique_beneficiaries == "Yes") %>% 
  group_by(state, beneficiary_type) %>% 
  summarise(beneficiaries = sum(beneficiaries)) %>%  
  pivot_wider(names_from = beneficiary_type, values_from = beneficiaries) %>% 
  adorn_totals(where = "row", na.rm = TRUE) %>% 
  adorn_percentages(denominator = "row", na.rm = TRUE) %>% 
  mutate_at(vars(`Host/local Community`, `Internally Displaced`, `Returnees`, `Rakhine stateless`), 
            .funs = list(~ . * 100)) %>% 
  left_join(fsc %>% 
              filter(!is.na(beneficiary_type) & unique_beneficiaries == "Yes") %>%
              group_by(state) %>%
              summarise(beneficiaries = sum(beneficiaries)), by = "state") %>% 
  pander(caption = "Percentage of beneficiaries by type, by state/region")

```

The states and sub-regions in which we are working the most with IDPs are Bago (East), Kachin, Chin, Shan (North) and Kayah. Overall, 75% of beneficiaries are from the host/local community, 14% are stateless persons from Rakhine and 11% are IDPs. 

```{r}
# checking recurrent beneficiaries 
fsc %>% 
  group_by(beneficiaries_recurrency, date) %>% 
  summarise(beneficiaries = sum(beneficiaries)) %>% 
  mutate(pc_of_total = beneficiaries / sum(beneficiaries)) %>% 
  ggplot(aes(x = date, y = beneficiaries)) +
  geom_line() +
  facet_wrap(~ beneficiaries_recurrency, scales = "free_y")

fsc %>%  
  group_by(beneficiaries_recurrency, frequency) %>% 
  summarise(beneficiaries = sum(beneficiaries)) %>% 
  filter(frequency == "Other")
```


```{r}

# for some reason, the mutate fct_reorder is not working
 
fsc %>% 
  filter(beneficiary_type != "NA") %>% 
  group_by(beneficiary_type) %>% 
  mutate(avg_hhd = beneficiaries / households, na.rm = TRUE) %>% 
  ggplot(aes(x = fct_reorder(beneficiary_type, avg_hhd), y = avg_hhd)) + 
  geom_boxplot() +
  scale_y_continuous(limits = c(0, 15)) +
  labs(x = "Beneficiary type", 
       y = "Average household size")

```

```{r}
fsc %>% 
  mutate(beneficiary_type = str_trim(beneficiary_type),
         (beneficiary_type = as.character(fct_recode(beneficiary_type, 
               "Rakhine stateless" = "Non-displaced stateless people in Rakhine")))) %>%
  filter(beneficiary_type != "NA") %>% 
  group_by(beneficiary_type) %>% 
 
  mutate(avg_hhd_size = beneficiaries / households,
         beneficiary_type = reorder(beneficiary_type, avg_hhd_size)) %>% 
  ggplot(aes(x = beneficiary_type, y = avg_hhd_size)) +
  geom_boxplot() +
  scale_y_continuous(limits = c(0, 20)) +
  labs(x = "Beneficiary type", 
       y = "Average household size")

```

